<!DOCTYPE HTML>
<html>
<head>
<title>WinClose | AutoHotkey</title>
<meta name="description" content="The WinClose command closes the specified window." />
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<link href="../static/theme.css" rel="stylesheet" type="text/css" />
<script src="../static/content.js" type="text/javascript"></script>
</head>
<body>

<h1>WinClose</h1>

<p>关闭指定的窗口.</p>

<pre class="Syntax"><span class="func">WinClose</span> <span class="optional">, WinTitle, WinText, SecondsToWait, ExcludeTitle, ExcludeText</span></pre>
<h2>参数</h2>
<dl>

  <dt>WinTitle</dt>
  <dd><p>窗口标题或识别目标窗口的其他条件. 请参阅 <a href="../misc/WinTitle.htm">WinTitle</a>.</p></dd>

  <dt>WinText</dt>
  <dd><p>如果使用此参数, 那么它必须是目标窗口中单个文本元素的子字符串(和内置的 Window Spy 工具显示的一样). 当 <a href="DetectHiddenText.htm">DetectHiddenText</a> 的设置为 ON 时, 那么会检测到隐藏文本元素.</p></dd>

  <dt>SecondsToWait</dt>
  <dd><p>如果省略或为空, 此命令会完全不等待. 如果为 0, 则它会等待 500ms. 否则, 它会等待指定的秒数(可以为小数或<a href="../Variables.htm#Expressions">表达式</a>) 来让窗口关闭. 如果窗口在此期间没有关闭, 那么脚本会继续执行. 此命令 <strong>不会</strong> 设置 ErrorLevel, 所以如果您需要确定窗口是否关闭时请使用 <a href="WinExist.htm">IfWinExist</a> 或 <a href="WinWaitClose.htm">WinWaitClose</a>. 当此命令处于等待状态时, 可以通过<a href="../Hotkeys.htm">热键</a>, <a href="Menu.htm">自定义菜单项</a>或<a href="SetTimer.htm">计时器</a>启动新的<a href="../misc/Threads.htm">线程</a>.</p></dd>

  <dt>ExcludeTitle</dt>
  <dd><p>标题中含有此参数值的窗口将被排除.</p></dd>

  <dt>ExcludeText</dt>
  <dd><p>文本中含有此参数值的窗口将被排除.</p></dd>

</dl>

<h2>备注</h2>
<p>此命令发送关闭消息到窗口. 结果取决于窗口(它可能会询问是否保存数据等).</p>
<p>如果匹配窗口是活动的, 那么会优先关闭此窗口而不是它下面的其他匹配窗口. 一般而言, 如果有多个匹配窗口, 那么会关闭最上面的(最近使用的) 窗口.</p>
<p>此命令仅对最上面的匹配窗口进行操作, 除非 <em>WinTitle</em> 为 <a href="GroupAdd.htm">ahk_group GroupName</a>, 此时会影响组中所有窗口.</p>
<p>WinClose 发送 WM_CLOSE 消息到目标窗口, 这种关闭方法有些强制性. 关闭窗口的另一种方法是发送下面的消息. 它可能会产生与此命令不同的行为, 因为它类似于按下 <kbd>Alt</kbd>+<kbd>F4</kbd> 或点击窗口标题栏的关闭按钮的效果:</p>
<pre>PostMessage, 0x112, 0xF060,,, WinTitle, WinText  <em>; 0x112 = WM_SYSCOMMAND, 0xF060 = SC_CLOSE</em></pre>
<p>如果使用 WinClose 无法关闭窗口, 那么您可以使用 <a href="WinKill.htm">WinKill</a> 来强制关闭.</p>
<p>窗口标题和文本是区分大小写的. 只有在打开 <a href="DetectHiddenWindows.htm">DetectHiddenWindows</a> 设置时, 才能检测到隐藏窗口.</p>
<h2>相关</h2>
<p><a href="WinKill.htm">WinKill</a>, <a href="WinWaitClose.htm">WinWaitClose</a>, <a href="Process.htm">Process</a>, <a href="WinActivate.htm">WinActivate</a>, <a href="SetTitleMatchMode.htm">SetTitleMatchMode</a>, <a href="DetectHiddenWindows.htm">DetectHiddenWindows</a>, <a href="../misc/WinTitle.htm#LastFoundWindow">上次找到的窗口</a>, <a href="WinExist.htm">IfWinExist</a>, <a href="WinActive.htm">IfWinActive</a>, <a href="WinWaitActive.htm">WinWaitActive</a>, <a href="WinWait.htm">WinWait</a>, <a href="GroupActivate.htm">GroupActivate</a></p>
<h2>示例</h2>
<pre class="NoIndent">IfWinExist, Untitled - Notepad
    WinClose <em>; 使用前面找到的窗口</em>
else
    WinClose, Calculator</pre>

</body>
</html>